#cal-btns-wrap {
  background: #a2a9ea;
}

#cal-btns-wrap button.mat-button {
  font-size: 18px;
}
#cal-btns-wrap button.arrow-btn {
  height: 50px; width: 50px;
  min-width: 50px;
  min-height: 50px;
}
#cal-table {
  text-align: center;
  background: white;
  width: 600px;
  border-radius: 30px;
}
#cal-table th {
  font-size: 18px;
}
#cal-table th, .week-num, .day-num {
  height: 40px; width: 40px;
}
.week-num > button.mat-button, .day-num > button.mat-button {
  font-size: 14px;
  width: 100%;
  height: 100%;
  min-width: 100%;
  min-height: 100%;
  padding: 0; margin: 0;
}
.week-num > button.mat-button {
  background-color: #3192de;
  color: #fff;
  width: 40px;
  height: 40px;
  min-width: 50%;
  min-height: 50%;
  -webkit-border-radius: 50%;
}

.day-num > button.mat-button {
  color: #999;
}
.day-num > button.mat-button.today {
  font-weight: bold;
}
.day-num > button.mat-button.curr {
  color: #333;
}
.curr.icon-yellow {
  background-image: url(assets/images/yellow.png);
  background-repeat: no-repeat;
  background-position: center;
}

.curr.icon-green {
  background-image: url(assets/images/green.png);
  background-repeat: no-repeat;
  background-position: center;
}

.curr.icon-red {
  background-image: url(assets/images/red.png);
  background-repeat: no-repeat;
  background-position: center;
}

.day-num > button.mat-button.today.curr {
  color: red;
}

.day-num > button.mat-button.active {
  background-color: #e0e0e0;
  width: 40px;
  height: 40px;
  min-width: 50%;
  min-height: 50%;
  -webkit-border-radius: 50%;
}

i {
  padding-left: 10px;
}